Skip to content

Conversation

@LagginTimes
Copy link
Contributor

@LagginTimes LagginTimes commented Aug 1, 2025

Implements #1942.

Description

This PR adds a new doctest demonstrating how to simulate a minimum confirmation threshold for confirmed balance calculations by adjusting the chain_tip height passed to TxGraph::balance.

Changelog notice

  • Added a doctest illustrating how to filter confirmed balance results by simulating a minimum confirmation threshold via chain_tip height.

Checklists

All Submissions:

New Features:

  • I've added tests for the new feature
  • I've added docs for the new feature

Bugfixes:

  • This pull request breaks the existing API
  • I've added tests to reproduce the issue which are now passing
  • I'm linking the issue being fixed by this PR

Copy link
Member

@evanlinjin evanlinjin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for working on this.

I do not think modifying the canonicalization is the right approach.

For example, if we have a min-confirmation-count of 3. We expect that a transaction confirmed at depth 2 should be prioritized over a transaction with no confirmations. With the current state of the PR, this guarantee is nonexistent.

Additionally, different min-confirmation-count values should not influence the Balance::total value. It should only shift values between *pending,immature,confirmed.

Idea 1

The simplest solution would be to not do any code changes and provide a doctest showing how we could manipulate the chain_tip input of TxGraph::[try_]balance. I.e. with LocalChain/CheckPoints.

let tip = chain.tip();

let target_height = tip.height().saturating_sub(confirmation_threshold);

let target_tip = tip
    .range(..=target_height)
    .next()
    .expect("checkpoint from local chain must have genesis");

// Use `target_tip` as the `chain_tip` input of `TxGraph::[try_]balance`.

For bdk_wallet::Wallet, we should probably provide a convenience method of sorts so the caller does not need to dig into the internal structures.

Idea 2

We can change the trust_predicate to be a more general predicate.

pub fn balance(
    /* Other Inputs */
    
    // predicate inputs: (txout_meta, txout, tip_height)
    mut predicate: impl FnMut(&OI, FullTxOut<A>, u32) -> BalanceType,
) -> Balance { todo!() }

// Maybe put this in `bdk_core`?
pub enum BalanceType {
    Immature,
    TrustedPending,
    UntrustedPending,
    Confirmed,
}

However, this is a breaking change and it makes it more involved to implement the predicate.


Let me know what you think.

@LagginTimes LagginTimes marked this pull request as draft August 4, 2025 14:18
@LagginTimes
Copy link
Contributor Author

LagginTimes commented Aug 6, 2025

Thank you for working on this.
...
Let me know what you think.

Thanks for the suggestions. I like Idea 1, and will work on implementing this.

@LagginTimes LagginTimes marked this pull request as ready for review August 7, 2025 05:58
@LagginTimes LagginTimes changed the title feat(chain): variable block confirmation for confirmed balances docs(chain): variable block confirmation for confirmed balances Aug 7, 2025
@LagginTimes LagginTimes changed the title docs(chain): variable block confirmation for confirmed balances docs(chain): add doctest for min confirmation balance filtering Aug 7, 2025
@LagginTimes LagginTimes requested a review from evanlinjin August 8, 2025 18:10
@LagginTimes LagginTimes added this to the Wallet 3.0.0 milestone Aug 26, 2025
@LagginTimes LagginTimes moved this to Discussion in BDK Chain Aug 26, 2025
@LagginTimes LagginTimes moved this from Discussion to Needs Review in BDK Chain Aug 26, 2025
@LagginTimes LagginTimes moved this from Needs Review to Discussion in BDK Chain Aug 26, 2025
@LagginTimes LagginTimes marked this pull request as draft September 1, 2025 07:26
@LagginTimes LagginTimes marked this pull request as ready for review September 5, 2025 08:18
Copy link
Contributor

@oleonardolima oleonardolima left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK 657a044

Copy link
Member

@evanlinjin evanlinjin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK 657a044

@oleonardolima oleonardolima merged commit 27ba19f into bitcoindevkit:master Sep 8, 2025
29 of 34 checks passed
@github-project-automation github-project-automation bot moved this from Discussion to Done in BDK Chain Sep 8, 2025
@oleonardolima oleonardolima mentioned this pull request Sep 12, 2025
24 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

Archived in project

Development

Successfully merging this pull request may close these issues.

3 participants